.sidebar{-webkit-overflow-scrolling:touch;background:linear-gradient(180deg,#0d1b4a,#1a237e);box-shadow:4px 0 24px #0003;color:#fff;display:flex;flex-direction:column;height:100vh;height:100dvh;left:-280px;overflow-y:auto;position:fixed;top:0;transition:left .3s cubic-bezier(.4,0,.2,1);width:260px;z-index:100}.sidebar.open{left:0}.sidebar-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;padding:16px}.sidebar-header,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{gap:10px}.logo-icon{font-size:32px}.logo-text{display:flex;flex-direction:column}.logo-title{color:#ffd54f;font-size:16px;font-weight:700;letter-spacing:2px}.logo-subtitle{color:#ffffff80;font-size:10px;letter-spacing:3px;text-transform:uppercase}.sidebar-close{background:none;border:none;border-radius:8px;color:#fff;cursor:pointer;display:block;font-size:20px;padding:8px}.sidebar-user{border-bottom:1px solid #ffffff1a;gap:10px;padding:14px 16px}.sidebar-user,.user-avatar{align-items:center;display:flex}.user-avatar{background:#ffd54f;border-radius:50%;color:#1a237e;flex-shrink:0;font-size:15px;font-weight:700;height:40px;justify-content:center;width:40px}.user-details{display:flex;flex-direction:column;overflow:hidden}.user-name{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{background:#ffd54f26;border-radius:8px;color:#ffd54f;display:inline-block;font-size:10px;margin-top:3px;max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content;padding:2px 8px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px 10px}.nav-item{-webkit-tap-highlight-color:transparent;align-items:center;border-radius:10px;color:#ffffffb3;display:flex;font-size:14px;font-weight:500;gap:10px;margin-bottom:2px;padding:11px 14px;text-decoration:none;transition:all .2s ease}.nav-item:active{transform:scale(.97)}.nav-item:hover{background:#ffffff14;color:#fff}.nav-item.active{background:#ffffff26;color:#ffd54f;font-weight:600}.nav-icon{font-size:18px;text-align:center;width:24px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:12px 16px}.logout-btn-sidebar{align-items:center;background:#ffffff14;border:none;border-radius:10px;color:#ffffffb3;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 14px;transition:all .2s ease;width:100%}.logout-btn-sidebar:hover{background:#ef444433;color:#fca5a5}@media (min-width:1024px){.sidebar{left:0}.sidebar-close{display:none}}.bottom-nav{background:#fff;border-top:1px solid #e8eaf0;bottom:0;box-shadow:0 -2px 12px #0000000f;display:none;justify-content:space-around;left:0;padding:6px 8px;position:fixed;right:0;z-index:80}.bottom-nav-item{align-items:center;border-radius:12px;color:#999;display:flex;flex-direction:column;font-size:10px;font-weight:500;gap:3px;padding:6px 10px;text-decoration:none}.bottom-nav-item.active{color:#1a237e;font-weight:600}.bottom-nav-icon{font-size:20px}@media (max-width:767px){.bottom-nav{display:flex}}.app-layout{background:#f0f2f5;display:flex;min-height:100vh;min-height:100dvh}.sidebar-overlay{background:#00000080;inset:0;opacity:0;position:fixed;transition:all .3s ease;visibility:hidden;z-index:90}.sidebar-overlay.active{opacity:1;visibility:visible}.main-area{display:flex;flex:1 1;flex-direction:column;height:100vh;height:100dvh;min-width:0;overflow:hidden}.content{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;overscroll-behavior:contain}@media (min-width:1024px){.main-area{margin-left:260px}.sidebar-overlay{display:none}.content{padding:24px 28px}}@media (min-width:768px) and (max-width:1023px){.content{padding:20px}}@media (max-width:767px){.content{padding:12px 12px 85px}}.dashboard-admin,.dashboard-gvcn,.dashboard-gvphu,.dashboard-truongnganh{margin:0 auto;max-width:900px;padding:20px 16px}.admin-stats-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);margin-bottom:18px}@media (min-width:600px){.admin-stats-grid{grid-template-columns:repeat(4,1fr)}}.admin-stat-card{background:#fff;border:1px solid #0000;border-radius:14px;box-shadow:0 1px 4px #0000000f;cursor:pointer;padding:16px 12px;text-align:center;transition:all .2s}.admin-stat-card:hover{border-color:#e8eaf0;box-shadow:0 4px 12px #00000014;transform:translateY(-1px)}.admin-stat-card.highlight{background:#e8f5e9}.admin-stat-icon{display:block;font-size:24px;margin-bottom:4px}.admin-stat-value{color:#1a237e;display:block;font-size:22px;font-weight:800}.admin-stat-label{color:#888;font-size:11px;margin-top:2px}.admin-alerts{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.admin-alert{align-items:center;border-radius:12px;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;padding:12px 14px}.admin-alert.warning{background:#fff3e0;color:#e65100}.admin-alert.danger{background:#ffebee;color:#c62828}.admin-alert.success{background:#e8f5e9;color:#2e7d32}.admin-section-title{color:#1a1a2e;font-size:16px;font-weight:700;margin:0 0 10px}.admin-actions-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}@media (min-width:500px){.admin-actions-grid{grid-template-columns:repeat(4,1fr)}}.admin-action-card{background:#fff;border:1px solid #0000;border-radius:14px;box-shadow:0 1px 4px #0000000f;cursor:pointer;padding:20px 14px;text-align:center;transition:all .2s}.admin-action-card:hover{border-color:#1a237e;box-shadow:0 4px 12px #1a237e1a;transform:translateY(-2px)}.admin-action-icon{display:block;font-size:28px;margin-bottom:6px}.admin-action-label{color:#1a1a2e;font-size:13px;font-weight:700}.gvcn-hero-card{align-items:center;background:linear-gradient(135deg,#0d47a1,#1565c0);border-radius:16px;color:#fff;display:flex;justify-content:space-between;margin-bottom:18px;padding:18px 20px}.gvcn-hero-left h2{font-size:18px;font-weight:700;margin:0 0 6px}.gvcn-hero-stats{font-size:13px;opacity:.9}.gvcn-btn-primary{background:#ffd54f;border:none;border-radius:12px;color:#1a237e;cursor:pointer;font-size:14px;font-weight:700;padding:12px 20px;transition:all .2s;white-space:nowrap}.gvcn-btn-primary:hover{background:#ffb300}.gvcn-actions{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:18px}.gvcn-action-card{background:#fff;border:1px solid #0000;border-radius:14px;box-shadow:0 1px 4px #0000000f;cursor:pointer;padding:16px 12px;text-align:center;transition:all .2s}.gvcn-action-card:hover{border-color:#1a237e;box-shadow:0 4px 12px #1a237e1a;transform:translateY(-2px)}.gvcn-action-icon{display:block;font-size:26px;margin-bottom:4px}.gvcn-action-label{color:#1a1a2e;display:block;font-size:13px;font-weight:700}.gvcn-action-desc{color:#888;font-size:10px;margin-top:2px}.gvcn-birthday{align-items:center;background:linear-gradient(135deg,#fff9c4,#fff8e1);border-radius:12px;display:flex;flex-wrap:wrap;font-size:13px;font-weight:500;gap:8px;margin-bottom:18px;padding:12px 16px}.gvcn-birthday.upcoming{background:#f5f5f5}.gvcn-birthday-name{background:#fff;border-radius:16px;color:#e65100;cursor:pointer;font-weight:600;padding:4px 10px}.gvcn-birthday-name:hover{background:#ffe0b2}.gvcn-section-title{color:#1a1a2e;font-size:16px;font-weight:700;margin:0 0 10px}.gvcn-student-list{display:flex;flex-direction:column;gap:8px}.gvcn-student-item{align-items:center;background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000a;cursor:pointer;display:flex;gap:12px;padding:14px 16px;transition:all .2s}.gvcn-student-item:hover{box-shadow:0 4px 12px #00000014;transform:translateX(4px)}.gvcn-student-avatar{align-items:center;background:#e8eaf6;border-radius:50%;color:#1a237e;display:flex;flex-shrink:0;font-size:15px;font-weight:700;height:40px;justify-content:center;width:40px}.gvcn-student-info{flex:1 1}.gvcn-student-info strong{display:block;font-size:14px}.gvcn-student-info span{color:#888;font-size:11px}.gvcn-student-arrow{color:#1a237e;font-size:18px;font-weight:700}.tnganh-hero-card{background:linear-gradient(135deg,#00695c,#00897b);border-radius:16px;color:#fff;margin-bottom:18px;padding:18px 20px}.tnganh-hero-card h2{font-size:18px;font-weight:700;margin:0 0 12px}.tnganh-hero-stats{display:flex;gap:20px}.tnganh-stat{text-align:center}.tnganh-stat-value{display:block;font-size:22px;font-weight:800}.tnganh-stat-label{font-size:11px;opacity:.8}.tnganh-section-title{color:#1a1a2e;font-size:16px;font-weight:700;margin:0 0 10px}.tnganh-empty{background:#fff;border-radius:14px;color:#999;margin-bottom:18px;padding:40px 20px;text-align:center}.tnganh-empty span{display:block;font-size:48px;margin-bottom:8px}.tnganh-empty button{background:#1a237e;border:none;border-radius:10px;color:#fff;cursor:pointer;font-weight:600;margin-top:12px;padding:10px 20px}.tnganh-actions{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}.tnganh-action-card{background:#fff;border:1px solid #0000;border-radius:14px;box-shadow:0 1px 4px #0000000f;cursor:pointer;padding:18px 14px;text-align:center;transition:all .2s}.tnganh-action-card:hover{border-color:#1a237e;transform:translateY(-2px)}.tnganh-action-icon{display:block;font-size:28px;margin-bottom:6px}.tnganh-action-label{color:#1a1a2e;font-size:13px;font-weight:700}.gvphu-hero-card{background:linear-gradient(135deg,#4a148c,#7b1fa2);border-radius:16px;color:#fff;margin-bottom:20px;padding:18px 20px;text-align:center}.gvphu-hero-card h2{font-size:18px;font-weight:700;margin:0 0 4px}.gvphu-hero-card p{font-size:13px;margin:0;opacity:.8}.gvphu-main-action{display:flex;justify-content:center}.gvphu-btn-huge{align-items:center;background:#fff;border:2px solid #1a237e;border-radius:20px;box-shadow:0 2px 8px #0000000f;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:28px 40px;transition:all .2s}.gvphu-btn-huge:hover{background:#e8eaf6;transform:scale(1.02)}.gvphu-btn-icon{font-size:48px}.gvphu-btn-text{color:#1a237e;font-size:20px;font-weight:800}.gvphu-btn-sub{color:#888;font-size:12px}.fade-in{animation:fadeIn .4s ease}.unsaved-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:999}.unsaved-box{animation:fadeIn .2s ease;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0003;max-width:420px;padding:28px;text-align:center;width:90%}.unsaved-box h3{color:#e65100;font-size:18px;margin:0 0 8px}.unsaved-box p{color:#666;font-size:14px;margin:0 0 20px}.unsaved-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.unsaved-actions button{border:none;border-radius:10px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.unsaved-btn-cancel{background:#f5f5f5;color:#666}.unsaved-btn-leave{background:#ffebee;color:#c62828}.unsaved-btn-save{background:#1a237e;color:#fff}.bottomsheet-overlay{background:#00000080;inset:0;opacity:0;position:fixed;transition:all .3s ease;visibility:hidden;z-index:200}.bottomsheet-overlay.active{opacity:1;visibility:visible}.bottomsheet{background:#fff;border-radius:20px 20px 0 0;bottom:0;box-shadow:0 -4px 20px #00000026;display:flex;flex-direction:column;left:0;max-height:70vh;position:fixed;right:0;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:201}.bottomsheet.active{transform:translateY(0)}.bottomsheet-handle{background:#ddd;border-radius:2px;height:4px;margin:10px auto 0;width:36px}.bottomsheet-header{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;flex-shrink:0;justify-content:space-between;padding:12px 20px 8px}.bottomsheet-header h3{color:#1a1a2e;font-size:16px;font-weight:700;margin:0}.bottomsheet-close{align-items:center;background:#f0f0f0;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:14px;height:28px;justify-content:center;transition:all .2s;width:28px}.bottomsheet-close:hover{background:#e0e0e0;color:#333}.bottomsheet-body{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:16px 20px 30px}.diemdanh-page{margin:0 auto;max-width:700px;padding-bottom:100px}.dd-header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.dd-header-top h2{color:#1a237e;font-size:20px;font-weight:700;margin:0}.dd-lop-badge{background:#1a237e;border-radius:20px;color:#fff;font-size:13px;font-weight:600;padding:6px 14px}.dd-date-picker{background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000d;gap:8px;margin-bottom:10px;padding:10px}.dd-date-btn,.dd-date-picker{align-items:center;display:flex;justify-content:center}.dd-date-btn{background:#f0f2f5;border:none;border-radius:50%;color:#1a237e;cursor:pointer;font-size:13px;height:34px;transition:all .2s;width:34px}.dd-date-btn:active{background:#1a237e;color:#fff}.dd-date-display{border-radius:8px;cursor:pointer;min-width:100px;padding:4px 8px;text-align:center}.dd-date-display:hover{background:#f5f5f5}.dd-date-text{color:#1a237e;display:block;font-size:16px;font-weight:700}.dd-date-label{color:#999;font-size:11px}.dd-search-box{align-items:center;background:#fff;border:2px solid #e8eaf0;border-radius:12px;display:flex;margin-bottom:8px;padding:0 12px}.dd-search-box:focus-within{border-color:#1a237e}.dd-search-box input{background:#0000;border:none;flex:1 1;font-size:14px;outline:none;padding:11px 10px}.dd-clear-btn{align-items:center;background:#e0e0e0;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:11px;height:24px;justify-content:center;width:24px}.dd-filter-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.dd-filter-tag{background:#f5f5f5;border:2px solid #0000;border-radius:20px;color:#666;cursor:pointer;font-size:12px;font-weight:600;gap:4px;padding:7px 12px;transition:all .2s}.dd-filter-tag,.dd-mark-all{align-items:center;display:flex}.dd-mark-all{color:#888;flex-wrap:wrap;font-size:11px;gap:6px;margin-bottom:10px}.dd-mark-btn{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:14px;height:30px;justify-content:center;transition:all .15s;width:30px}.dd-mark-btn:active{transform:scale(.9)}.dd-stats{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(5,1fr);margin-bottom:6px}.dd-stat-item{align-items:center;border-radius:12px;display:flex;flex-direction:column;padding:8px 4px;text-align:center}.dd-stat-count{font-size:20px;font-weight:800}.dd-stat-label{font-size:10px;font-weight:500}.dd-total{color:#888;font-size:13px;margin-bottom:14px;text-align:center}.dd-total strong{color:#1a237e}.dd-changed{color:#f44336;font-weight:600}.dd-saved-indicator{color:#4caf50;font-weight:600}.dd-filtered{color:#1a237e;font-weight:500}.dd-message{animation:fadeIn .3s ease;border-radius:10px;font-size:14px;font-weight:500;margin-bottom:12px;padding:10px 16px;text-align:center}.dd-message.success{background:#e8f5e9;color:#2e7d32}.dd-message.error{background:#ffebee;color:#c62828}.dd-loading{padding:40px}.dd-empty,.dd-loading{color:#999;text-align:center}.dd-empty{padding:40px 20px}.dd-empty span{display:block;font-size:48px;margin-bottom:8px}.dd-list{display:flex;flex-direction:column;gap:8px;margin-bottom:80px}.dd-card{background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000d;overflow:hidden;transition:all .2s}.dd-card.expanded{box-shadow:0 2px 12px #0000001a}.dd-card-null{border-left:3px solid #9e9e9e}.dd-card-main{-webkit-tap-highlight-color:transparent;justify-content:space-between;padding:12px 14px;-webkit-user-select:none;user-select:none}.dd-card-left,.dd-card-main{align-items:center;display:flex}.dd-card-left{cursor:pointer;flex:1 1;gap:10px;min-width:0}.dd-avatar{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:16px;font-weight:700;height:40px;justify-content:center;width:40px}.dd-card-info{display:flex;flex-direction:column;min-width:0}.dd-card-name{color:#1a1a2e;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dd-card-detail{color:#999;font-size:11px}.dd-card-right{align-items:center;display:flex;flex-shrink:0;gap:6px}.dd-status-badge{border-radius:20px;cursor:pointer;font-size:12px;font-weight:600;padding:5px 10px;white-space:nowrap}.dd-status-null{background:#f5f5f5!important;border:1px dashed #bdbdbd;color:#9e9e9e!important}.dd-expand-btn{background:none;border:none;color:#ccc;cursor:pointer;font-size:12px;padding:4px 6px}.dd-card-expand{padding:0 14px 12px}.dd-status-options{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(4,1fr);margin-bottom:8px}.dd-status-option{border:2px solid #0000;border-radius:10px;cursor:pointer;font-size:11px;font-weight:600;padding:8px 4px;text-align:center;transition:all .15s}.dd-status-option:active{transform:scale(.95)}.dd-ghichu input{background:#fafafa;border:1px solid #e0e0e0;border-radius:10px;font-size:13px;outline:none;padding:10px 12px;width:100%}.dd-ghichu input:focus{background:#fff;border-color:#1a237e}.dd-save-bar{display:flex;justify-content:center;padding:20px 0 40px}.dd-btn-save{background:#1a237e;border:none;border-radius:30px;box-shadow:0 4px 16px #1a237e4d;color:#fff;cursor:pointer;font-size:15px;font-weight:700;padding:14px 36px;transition:all .2s;white-space:nowrap}.dd-btn-save:active{transform:scale(.95)}.dd-btn-save:disabled{cursor:not-allowed;opacity:.6}.dd-btn-save.saved{background:#4caf50}@media (max-width:500px){.dd-stats{grid-template-columns:repeat(3,1fr)}}@media (max-width:400px){.dd-stats,.dd-status-options{grid-template-columns:repeat(2,1fr)}.dd-status-badge{font-size:10px;padding:4px 6px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.sp-phone-link{color:#2196f3;cursor:pointer;font-weight:600;text-decoration:none;transition:all .2s}.sp-phone-link:hover{color:#1565c0;text-decoration:underline}.timeline{display:flex;flex-direction:column;padding:8px 0}.timeline-item{display:flex;gap:14px}.timeline-left{flex-direction:column}.timeline-dot,.timeline-left{align-items:center;display:flex;flex-shrink:0;width:40px}.timeline-dot{background:#fff;border:3px solid #ccc;border-radius:50%;height:40px;justify-content:center;z-index:2}.timeline-line{background:#e0e0e0;flex:1 1;margin:4px 0;min-height:24px;width:2px}.timeline-content{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:8px 0 20px}.timeline-date{color:#1a1a2e;font-size:14px;font-weight:700}.timeline-status{font-size:13px;font-weight:600}.timeline-note{background:#f9f9f9;border-radius:8px;color:#888;display:inline-block;font-size:12px;margin-top:4px;max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content;padding:4px 10px}.nd-container{margin:0 auto;max-width:100%;padding:0 16px 20px}.nd-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:10px}.nd-header h2{color:#1a237e;font-size:20px;font-weight:700;margin:0}.nd-view-only{color:#888;font-size:13px;font-weight:400}.nd-header-left{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.nd-btn-save-top{background:linear-gradient(135deg,#1a237e,#283593);border:none;border-radius:10px;box-shadow:0 2px 8px #1a237e33;color:#fff;cursor:pointer;font-size:13px;font-weight:700;padding:8px 16px;white-space:nowrap}.nd-btn-save-top:active{transform:scale(.95)}.nd-btn-save-top:disabled{cursor:not-allowed;opacity:.5}.nd-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.nd-filter-input{border:2px solid #e8eaf0;border-radius:12px;flex:1 1;font-size:14px;min-width:120px;outline:none;padding:10px 14px}.nd-filter-input:focus{border-color:#1a237e}.nd-sort-select{background:#fff}.nd-select-lop,.nd-sort-select{border:2px solid #e8eaf0;border-radius:12px;font-size:14px;outline:none;padding:10px 14px}.nd-empty-state{color:#999;padding:60px 20px;text-align:center}.nd-empty-state span{display:block;font-size:56px;margin-bottom:12px}.nd-loading{color:#999;padding:40px;text-align:center}.nd-table-wrapper{-webkit-overflow-scrolling:touch;background:#fff;border-radius:16px;box-shadow:0 1px 6px #0000000a;overflow-x:auto}.nd-table{border-collapse:collapse;min-width:650px;width:100%}.nd-table th{background:#f5f6fa;border-bottom:2px solid #e8eaf0;color:#1a237e;font-size:11px;font-weight:700;letter-spacing:.5px;padding:12px 6px;text-align:center;text-transform:uppercase}.nd-table td{border-bottom:1px solid #f0f0f0;padding:10px 6px;text-align:center;vertical-align:middle}.nd-row-changed td{background:#fffde7}.nd-th-stt{background:#f5f6fa;width:30px;z-index:2}.nd-td-stt,.nd-th-stt{left:0;position:-webkit-sticky;position:sticky}.nd-td-stt{background:#fff;z-index:1}.nd-th-name{background:#f5f6fa;min-width:140px;z-index:2}.nd-td-name,.nd-th-name{left:30px;position:-webkit-sticky;position:sticky;text-align:left!important}.nd-td-name{background:#fff;z-index:1}.nd-row-changed .nd-td-name,.nd-row-changed .nd-td-stt{background:#fffde7}.nd-th-diem{min-width:70px}.nd-th-hk{background:#fff3e0}.nd-th-tb{background:#e8eaf6;width:50px}.nd-th-xl{width:100px}.nd-hs-name{color:#1a1a2e;cursor:pointer;font-size:13px;font-weight:600;white-space:nowrap}.nd-hs-name:hover{color:#1a237e;text-decoration:underline}.nd-td-hk{background:#fff8e1}.nd-td-tb{background:#f5f6ff}.nd-tb-value{font-size:15px;font-weight:700}.nd-input-group{align-items:center;display:flex;flex-wrap:wrap;gap:3px;justify-content:center}.nd-input-diem{border:2px solid #e8eaf0;border-radius:8px;font-size:13px;outline:none;padding:7px 2px;text-align:center;transition:all .2s;width:42px}.nd-input-diem:focus{border-color:#1a237e;box-shadow:0 0 0 2px #1a237e1a}.nd-input-diem:disabled{background:#f9f9f9;color:#999}.nd-input-hk{background:#fff8e1;border-color:#ffcc80;font-weight:700}.nd-btn-add-row{align-items:center;background:#fafafa;border:1px dashed #ccc;border-radius:50%;color:#1a237e;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:24px;justify-content:center;width:24px}.nd-btn-add-row:hover{background:#e8eaf6;border-color:#1a237e}.nd-xl-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:700;padding:4px 10px;white-space:nowrap}@media (max-width:500px){.nd-container{padding:0 8px 20px}.nd-header h2{font-size:17px}.nd-th-stt{font-size:9px;padding:0 1px;width:18px}.nd-td-stt{font-size:10px;padding:0 1px}.nd-th-name{min-width:80px}.nd-td-name,.nd-th-name{left:18px;padding:0 6px}.nd-hs-name{display:block;font-size:12px;line-height:1.3;white-space:normal;word-break:break-word}.nd-input-diem{font-size:11px;padding:5px 1px;width:30px}.nd-input-group{gap:1px}.nd-th-diem{min-width:42px}.nd-table th{font-size:9px;padding:8px 2px}.nd-table td{padding:6px 2px}.nd-th-tb{width:32px}.nd-th-xl{width:50px}.nd-tb-value{font-size:13px}.nd-xl-badge{font-size:9px;padding:2px 4px}.nd-btn-add-row{font-size:10px;height:18px;width:18px}.nd-filter-input,.nd-select-lop,.nd-sort-select{font-size:12px;padding:8px 10px}}.qlhs-container{margin:0 auto;max-width:1000px;padding-bottom:40px}.qlhs-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.qlhs-header h2{color:#1a237e;font-size:24px;font-weight:700;margin:0}.qlhs-count{color:#888;display:block;font-size:13px;margin-top:2px}.qlhs-btn-add{background:linear-gradient(135deg,#1a237e,#283593);border:none;border-radius:12px;box-shadow:0 2px 8px #1a237e33;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.qlhs-btn-add:hover{box-shadow:0 4px 16px #1a237e4d;transform:translateY(-1px)}.qlhs-btn-add:active{transform:scale(.97)}.qlhs-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.qlhs-search-box{align-items:center;background:#fff;border:2px solid #e8eaf0;border-radius:12px;display:flex;flex:1 1;min-width:200px;padding:0 14px;transition:all .2s}.qlhs-search-box:focus-within{border-color:#1a237e;box-shadow:0 0 0 3px #1a237e0f}.qlhs-search-icon{font-size:16px;margin-right:8px;opacity:.4}.qlhs-search-box input{background:#0000;border:none;flex:1 1;font-size:14px;outline:none;padding:12px 0}.qlhs-clear-btn{align-items:center;background:#e0e0e0;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:11px;height:24px;justify-content:center;width:24px}.qlhs-select{background:#fff;border:2px solid #e8eaf0;border-radius:12px;cursor:pointer;font-size:14px;min-width:150px;outline:none;padding:12px 16px;transition:all .2s}.qlhs-select:focus{border-color:#1a237e}.qlhs-empty-state,.qlhs-loading{color:#999;padding:60px 20px;text-align:center}.qlhs-empty-state span{display:block;font-size:56px;margin-bottom:12px}.qlhs-empty-state p{font-size:15px;margin:0}.qlhs-list{display:flex;flex-direction:column;gap:10px}.qlhs-card{align-items:center;background:#fff;border:1px solid #0000;border-radius:16px;box-shadow:0 1px 6px #0000000a;display:flex;justify-content:space-between;padding:16px 18px;transition:all .2s}.qlhs-card:hover{border-color:#e8eaf0;box-shadow:0 4px 16px #00000014}.qlhs-card-left{flex:1 1;gap:14px;min-width:0}.qlhs-avatar,.qlhs-card-left{align-items:center;display:flex}.qlhs-avatar{border-radius:50%;flex-shrink:0;font-size:18px;font-weight:700;height:48px;justify-content:center;width:48px}.qlhs-card-info{flex:1 1;min-width:0}.qlhs-card-name{align-items:center;color:#1a1a2e;cursor:pointer;display:flex;flex-wrap:wrap;font-size:15px;font-weight:600;gap:8px;transition:color .2s}.qlhs-card-name:hover,.qlhs-thanh{color:#1a237e}.qlhs-thanh{font-size:13px;font-weight:500}.qlhs-card-detail{align-items:center;color:#888;display:flex;flex-wrap:wrap;font-size:12px;gap:8px;margin-top:3px}.qlhs-lop-tag{background:#e8eaf6;border-radius:12px;color:#1a237e;font-size:11px;font-weight:600;padding:2px 10px}.qlhs-card-contact{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px}.qlhs-phone-link{color:#2196f3;font-size:12px;font-weight:600;text-decoration:none;transition:color .2s}.qlhs-phone-link:hover{color:#1565c0;text-decoration:underline}.qlhs-card-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.qlhs-btn-icon{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;font-size:16px;height:38px;justify-content:center;transition:all .2s;width:38px}.qlhs-btn-icon:hover{background:#f5f5f5;border-color:#1a237e}.qlhs-btn-icon.delete:hover{background:#ffebee;border-color:#f44336}.qlhs-form{gap:8px}.qlhs-form,.qlhs-form-section{display:flex;flex-direction:column}.qlhs-form-section{background:#fafafa;border-radius:14px;gap:12px;padding:16px}.qlhs-form-section h4{color:#1a237e;font-size:14px;font-weight:700;margin:0}.qlhs-form-group{display:flex;flex-direction:column;gap:5px}.qlhs-form-group label{color:#666;font-size:12px;font-weight:600}.qlhs-form-group input,.qlhs-form-group select{background:#fff;border:2px solid #e8eaf0;border-radius:10px;font-size:14px;outline:none;padding:11px 14px;transition:all .2s}.qlhs-form-group input:focus,.qlhs-form-group select:focus{border-color:#1a237e;box-shadow:0 0 0 3px #1a237e0f}.qlhs-form-group input:disabled,.qlhs-form-group select:disabled{background:#f5f5f5;color:#999}.qlhs-form-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.qlhs-form-actions{display:flex;gap:12px;margin-top:8px}.qlhs-btn-cancel{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:12px;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:13px;transition:all .2s}.qlhs-btn-cancel:hover{background:#eee}.qlhs-btn-submit{background:linear-gradient(135deg,#1a237e,#283593);border:none;border-radius:12px;box-shadow:0 2px 8px #1a237e33;color:#fff;cursor:pointer;flex:2 1;font-size:14px;font-weight:600;padding:13px;transition:all .2s}.qlhs-btn-submit:hover{box-shadow:0 4px 16px #1a237e4d}.qlhs-btn-submit:disabled{cursor:not-allowed;opacity:.6}@media (max-width:600px){.qlhs-form-row{grid-template-columns:1fr}.qlhs-card-actions{flex-direction:column;gap:6px}.qlhs-card-contact{flex-direction:column;gap:4px}}.qlnd-container{margin:0 auto;max-width:900px;padding-bottom:40px}.qlnd-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px}.qlnd-header h2{color:#1a237e;font-size:24px;font-weight:700;margin:0}.qlnd-count{color:#888;display:block;font-size:13px;margin-top:2px}.qlnd-btn-add{background:linear-gradient(135deg,#1a237e,#283593);border:none;border-radius:12px;box-shadow:0 2px 8px #1a237e33;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.qlnd-btn-add:hover{box-shadow:0 4px 16px #1a237e4d;transform:translateY(-1px)}.qlnd-btn-add:active{transform:scale(.97)}.qlnd-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.qlnd-search-box{align-items:center;background:#fff;border:2px solid #e8eaf0;border-radius:12px;display:flex;flex:1 1;min-width:200px;padding:0 14px;transition:all .2s}.qlnd-search-box:focus-within{border-color:#1a237e;box-shadow:0 0 0 3px #1a237e0f}.qlnd-search-icon{font-size:16px;margin-right:8px;opacity:.4}.qlnd-search-box input{background:#0000;border:none;flex:1 1;font-size:14px;outline:none;padding:12px 0}.qlnd-clear-btn{align-items:center;background:#e0e0e0;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:11px;height:24px;justify-content:center;width:24px}.qlnd-select{background:#fff;border:2px solid #e8eaf0;border-radius:12px;cursor:pointer;font-size:14px;min-width:160px;outline:none;padding:12px 16px;transition:all .2s}.qlnd-select:focus{border-color:#1a237e}.qlnd-empty-state,.qlnd-loading{color:#999;padding:60px 20px;text-align:center}.qlnd-empty-state span{display:block;font-size:56px;margin-bottom:12px}.qlnd-empty-state p{font-size:15px;margin:0}.qlnd-list{display:flex;flex-direction:column;gap:10px}.qlnd-card{align-items:center;background:#fff;border:1px solid #0000;border-radius:16px;box-shadow:0 1px 6px #0000000a;display:flex;justify-content:space-between;padding:16px 18px;transition:all .2s}.qlnd-card:hover{border-color:#e8eaf0;box-shadow:0 4px 16px #00000014}.qlnd-card.inactive{background:#fafafa;opacity:.55}.qlnd-card-left{flex:1 1;gap:14px;min-width:0}.qlnd-avatar,.qlnd-card-left{align-items:center;display:flex}.qlnd-avatar{border-radius:50%;flex-shrink:0;font-size:18px;font-weight:700;height:48px;justify-content:center;width:48px}.qlnd-card-info{flex:1 1;min-width:0}.qlnd-card-name{align-items:center;color:#1a1a2e;display:flex;flex-wrap:wrap;font-size:15px;font-weight:600;gap:8px}.qlnd-thanh{color:#1a237e;font-size:13px;font-weight:500}.qlnd-badge-nghi{background:#ffebee;border-radius:20px;color:#c62828;font-size:11px;font-weight:600;padding:3px 10px}.qlnd-card-detail{color:#888;font-size:12px;margin-top:2px}.qlnd-card-roles{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.qlnd-role-tag{background:#e8eaf6;border-radius:20px;color:#1a237e;font-size:11px;font-weight:600;padding:3px 10px}.qlnd-role-tag.ngành{background:#e0f2f1;color:#00695c}.qlnd-role-tag.lop{background:#fff3e0;color:#e65100}.qlnd-card-actions{align-items:center;display:flex;flex-shrink:0;gap:8px}.qlnd-btn-icon{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;font-size:16px;height:38px;justify-content:center;transition:all .2s;width:38px}.qlnd-btn-icon:hover{background:#f5f5f5;border-color:#1a237e}.qlnd-btn-toggle{border:none;border-radius:10px;cursor:pointer;font-size:12px;font-weight:600;padding:8px 14px;transition:all .2s;white-space:nowrap}.qlnd-btn-toggle.deactivate{background:#fff3e0;color:#e65100}.qlnd-btn-toggle.deactivate:hover{background:#ffe0b2}.qlnd-btn-toggle.activate{background:#e8f5e9;color:#2e7d32}.qlnd-btn-toggle.activate:hover{background:#c8e6c9}.qlnd-form{gap:16px}.qlnd-form,.qlnd-form-group{display:flex;flex-direction:column}.qlnd-form-group{gap:5px}.qlnd-form-group label{color:#555;font-size:13px;font-weight:600}.qlnd-form-group input,.qlnd-form-group select{background:#fff;border:2px solid #e8eaf0;border-radius:12px;font-size:14px;outline:none;padding:12px 14px;transition:all .2s}.qlnd-form-group input:focus,.qlnd-form-group select:focus{border-color:#1a237e;box-shadow:0 0 0 3px #1a237e0f}.qlnd-form-group input:disabled{background:#f5f5f5;color:#999}.qlnd-form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.qlnd-role-checkboxes{display:flex;flex-wrap:wrap;gap:8px}.qlnd-role-checkbox{background:#fff;border:2px solid #e0e0e0;border-radius:24px;color:#666;cursor:pointer;font-size:13px;font-weight:600;padding:10px 16px;transition:all .2s}.qlnd-role-checkbox:hover{background:#f5f5ff;border-color:#1a237e}.qlnd-role-checkbox.active{background:#1a237e;border-color:#1a237e;box-shadow:0 2px 8px #1a237e40;color:#fff}.qlnd-no-lop{align-items:center;background:#fafafa;border:2px dashed #e0e0e0;border-radius:12px;color:#999;display:flex;flex-direction:column;font-size:13px;gap:10px;padding:16px;text-align:center}.qlnd-btn-add-lop{background:#1a237e;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px}.qlnd-form-actions{display:flex;gap:12px;margin-top:8px}.qlnd-btn-cancel{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:12px;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:13px;transition:all .2s}.qlnd-btn-cancel:hover{background:#eee}.qlnd-btn-submit{background:linear-gradient(135deg,#1a237e,#283593);border:none;border-radius:12px;box-shadow:0 2px 8px #1a237e33;color:#fff;cursor:pointer;flex:2 1;font-size:14px;font-weight:600;padding:13px;transition:all .2s}.qlnd-btn-submit:hover{box-shadow:0 4px 16px #1a237e4d}.qlnd-btn-submit:disabled{cursor:not-allowed;opacity:.6}@media (max-width:600px){.qlnd-form-row{grid-template-columns:1fr}.qlnd-card-actions{flex-direction:column;gap:6px}.qlnd-btn-toggle{font-size:11px;padding:6px 10px}}.cd-container{margin:0 auto;max-width:800px;padding-bottom:40px}.cd-container h2{color:#1a237e;font-size:24px;font-weight:700;margin-bottom:16px}.cd-tabs{display:flex;gap:6px;margin-bottom:16px}.cd-tab{background:#f5f5f5;border:none;border-radius:10px;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px;transition:all .2s}.cd-tab.active{background:#1a237e;color:#fff}.cd-toolbar{align-items:center;display:flex;justify-content:space-between;margin-bottom:14px}.cd-count{color:#888;font-size:13px}.cd-btn-add{background:#1a237e;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px}.cd-loading{color:#999;padding:40px;text-align:center}.cd-empty,.cd-empty-state{color:#999;padding:60px 20px;text-align:center}.cd-empty-state span{display:block;font-size:48px;margin-bottom:8px}.cd-list{display:flex;flex-direction:column;gap:8px}.cd-card{background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000d;justify-content:space-between;padding:14px 16px}.cd-card,.cd-card-left{align-items:center;display:flex}.cd-card-left{flex:1 1;gap:12px}.cd-color-dot{border-radius:50%;flex-shrink:0;height:24px;width:24px}.cd-card-info{display:flex;flex-direction:column;gap:2px}.cd-card-info strong{font-size:14px}.cd-card-info span{color:#888;font-size:12px}.cd-card-actions{display:flex;gap:6px}.cd-btn-icon{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;font-size:16px;height:36px;justify-content:center;width:36px}.cd-btn-icon.delete:hover{background:#ffebee;border-color:#f44336}.cd-form{gap:14px}.cd-form,.cd-form-group{display:flex;flex-direction:column}.cd-form-group{gap:4px}.cd-form-group label{color:#666;font-size:12px;font-weight:600}.cd-form-group input,.cd-form-group select{border:2px solid #e8eaf0;border-radius:10px;font-size:14px;outline:none;padding:10px 12px}.cd-form-row{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.cd-form-actions{display:flex;gap:10px;margin-top:8px}.cd-btn-cancel{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:10px;flex:1 1}.cd-btn-cancel,.cd-btn-submit{cursor:pointer;font-size:14px;font-weight:600;padding:12px}.cd-btn-submit{background:#1a237e;border:none;border-radius:10px;color:#fff;flex:2 1}.cd-btn-submit:disabled{opacity:.6}.cd-color-picker{display:flex;flex-wrap:wrap;gap:8px}.cd-color-btn{border:3px solid #0000;border-radius:50%;cursor:pointer;height:36px;transition:all .2s;width:36px}.cd-color-btn.active{border-color:#1a1a2e;box-shadow:0 0 0 3px #00000026}.student-profile{margin:0 auto;max-width:700px;padding-bottom:30px}.sp-empty,.sp-loading{color:#999;padding:60px 20px;text-align:center}.sp-empty span{display:block;font-size:48px;margin-bottom:8px}.spinner{animation:spin .8s linear infinite;height:30px;margin:0 auto 10px;width:30px}.sp-back-btn{background:none;border:none;color:#1a237e;cursor:pointer;font-size:16px;font-weight:600;margin-bottom:8px;padding:8px 0}.sp-header{background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000d;gap:14px;margin-bottom:14px;padding:16px}.sp-avatar-large,.sp-header{align-items:center;display:flex}.sp-avatar-large{background:linear-gradient(135deg,#1a237e,#3949ab);border-radius:50%;color:#fff;flex-shrink:0;font-size:22px;font-weight:700;height:56px;justify-content:center;width:56px}.sp-header-info h2{font-size:17px;font-weight:700;margin:0 0 2px}.sp-meta{color:#888;display:block;font-size:12px}.sp-tabs{display:flex;gap:6px;margin-bottom:14px}.sp-tab{background:#f5f5f5;border:none;border-radius:10px;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:10px 16px;transition:all .2s}.sp-tab.active{background:#1a237e;color:#fff}.sp-tab-content{display:flex;flex-direction:column;gap:12px}.sp-widget{background:#fff;border-radius:14px;border-top:3px solid #1a237e;box-shadow:0 1px 4px #0000000d;padding:14px 16px}.sp-widget h3{color:#1a1a2e;font-size:14px;font-weight:700;margin:0 0 10px}.sp-info-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.sp-info-item{display:flex;flex-direction:column;gap:2px}.sp-label{color:#999;font-size:10px;text-transform:uppercase}.sp-value{color:#1a1a2e;font-size:13px;font-weight:500}.sp-phone{color:#2196f3;font-weight:600}.sp-faith-list{display:flex;flex-direction:column;gap:6px}.sp-faith-item{color:#999;font-size:13px;padding:6px 0}.sp-faith-item.done{color:#4caf50;font-weight:600}.sp-stats-grid-2col{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.sp-stat-mini{align-items:center;background:#f9f9f9;border-radius:10px;color:#666;display:flex;flex-direction:column;font-size:12px;padding:8px}.sp-stat-num{font-size:22px;font-weight:800}.sp-stat-num.green{color:#4caf50}.sp-stat-num.orange{color:#ff9800}.sp-stat-num.blue{color:#2196f3}.sp-stat-num.red{color:#f44336}.sp-chuyen-can{align-items:baseline;display:flex;gap:6px;justify-content:center;margin:12px 0 8px}.sp-cc-label{color:#888;font-size:13px}.sp-cc-value{color:#1a237e;font-size:24px;font-weight:800}.sp-btn-detail{background:#f0f2f5;border:1px solid #e0e0e0;border-radius:10px;color:#1a237e;cursor:pointer;display:block;font-size:13px;font-weight:600;padding:10px;text-align:center;transition:all .2s;width:100%}.sp-btn-detail:hover{background:#e8eaf6;border-color:#1a237e}.sp-score-summary{align-items:center;display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.sp-score-big{color:#2196f3;font-size:36px;font-weight:800}.sp-score-label{color:#888;font-size:12px}.sp-xep-loai{font-size:14px;font-weight:600}.sp-history-card{border-top:3px solid #607d8b}.sp-history-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.sp-history-year{font-size:14px;font-weight:700}.sp-history-status{background:#f0f0f0;border-radius:10px;color:#666;font-size:11px;padding:2px 8px}.sp-history-status.active{background:#e8f5e9;color:#2e7d32}.sp-history-details{color:#666;font-size:13px}.sp-empty-text{color:#999;font-size:13px;padding:10px 0;text-align:center}@media (max-width:400px){.sp-info-grid{grid-template-columns:1fr}.sp-stats-grid-2col{grid-template-columns:1fr 1fr}}
/*
! tailwindcss v3.4.1 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]{display:none}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:-webkit-sticky;position:sticky}.inset-0{inset:0}.inset-y-0{bottom:0;top:0}.left-0{left:0}.right-0{right:0}.mb-1{margin-bottom:.25rem}.mb-6{margin-bottom:1.5rem}.ml-2{margin-left:.5rem}.block{display:block}.flex{display:flex}.table{display:table}.hidden{display:none}.h-16{height:4rem}.h-4{height:1rem}.min-h-screen{min-height:100vh}.w-16{width:4rem}.w-4{width:1rem}.w-full{width:100%}.max-w-md{max-width:28rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.5rem*var(--tw-space-y-reverse));margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(2rem*var(--tw-space-y-reverse));margin-top:calc(2rem*(1 - var(--tw-space-y-reverse)))}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-t{border-top-width:1px}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.border-transparent{border-color:#0000}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity))}.bg-blue-700{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity))}.bg-blue-900{--tw-bg-opacity:1;background-color:rgb(30 58 138/var(--tw-bg-opacity))}.bg-blue-900\/20{background-color:#1e3a8a33}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.bg-green-50{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.bg-cover{background-size:cover}.bg-center{background-position:50%}.p-3{padding:.75rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.pl-10{padding-left:2.5rem}.pl-3{padding-left:.75rem}.pr-10{padding-right:2.5rem}.pr-3{padding-right:.75rem}.pt-4{padding-top:1rem}.text-center{text-align:center}.font-sans{font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity))}.text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.text-green-800{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity))}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity))}.text-red-800{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.placeholder-gray-400::placeholder{--tw-placeholder-opacity:1;color:rgb(156 163 175/var(--tw-placeholder-opacity))}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-sm{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.outline{outline-style:solid}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.hover\:bg-blue-800:hover{--tw-bg-opacity:1;background-color:rgb(30 64 175/var(--tw-bg-opacity))}.hover\:text-blue-500:hover{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.focus\:border-blue-600:focus{--tw-border-opacity:1;border-color:rgb(37 99 235/var(--tw-border-opacity))}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.focus\:ring-1:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-1:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity))}.focus\:ring-blue-600:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(37 99 235/var(--tw-ring-opacity))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:640px){.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width:768px){.md\:flex{display:flex}.md\:w-1\/2{width:50%}.md\:p-10{padding:2.5rem}.md\:p-8{padding:2rem}}.dg-container{margin:0 auto;max-width:800px;padding:0 16px 40px}.dg-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:14px}.dg-header h2{color:#1a237e;font-size:20px;font-weight:700;margin:0}.dg-subtitle{color:#888;font-size:12px}.dg-header-right{display:flex;gap:8px}.dg-select{border:2px solid #e8eaf0;border-radius:12px;font-size:14px;outline:none;padding:10px 14px}.dg-stats{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);margin-bottom:12px}.dg-stat-item{background:#f5f5f5;border-radius:12px;padding:12px;text-align:center}.dg-stat-item.done{background:#e8f5e9}.dg-stat-item.pending{background:#fff3e0}.dg-stat-num{display:block;font-size:22px;font-weight:800}.dg-stat-label{color:#888;font-size:11px}.dg-filter-bar{display:flex;gap:6px;margin-bottom:12px}.dg-filter-btn{background:#fff;border:1px solid #e0e0e0;border-radius:20px;color:#666;cursor:pointer;font-size:12px;font-weight:600;padding:6px 14px}.dg-filter-btn.active{background:#1a237e;border-color:#1a237e;color:#fff}.dg-empty,.dg-loading{color:#999;padding:40px;text-align:center}.dg-empty span{display:block;font-size:56px;margin-bottom:12px}.spinner{animation:spin .7s linear infinite;border:3px solid #e0e0e0;border-radius:50%;border-top-color:#1a237e;height:32px;margin:0 auto 12px;width:32px}@keyframes spin{to{transform:rotate(1turn)}}.dg-list{display:flex;flex-direction:column;gap:8px}.dg-card{align-items:center;background:#fff;border-radius:14px;box-shadow:0 1px 4px #0000000a;cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px}.dg-card.done{border-left:3px solid #4caf50}.dg-card-left{align-items:center;display:flex;flex:1 1;gap:10px}.dg-card-stt{color:#999;font-size:13px;width:24px}.dg-card-avatar{align-items:center;background:#e8eaf6;border-radius:50%;color:#1a237e;display:flex;font-size:14px;font-weight:700;height:36px;justify-content:center;width:36px}.dg-card-info strong{display:block;font-size:14px}.dg-card-detail{align-items:center;color:#888;display:flex;flex-wrap:wrap;font-size:11px;gap:6px}.dg-badge{border-radius:8px;font-size:10px;font-weight:600;padding:1px 6px}.dg-card-status{font-size:18px}.dg-form-loading{color:#999;padding:40px;text-align:center}.dg-form{gap:16px;max-height:65vh;overflow-y:auto;padding-bottom:8px}.dg-form,.dg-form-section{display:flex;flex-direction:column}.dg-form-section{gap:8px}.dg-form-section h4{color:#1a237e;font-size:14px;margin:0}.dg-form-section label{color:#444;font-size:13px;font-weight:600}.dg-sub-label{color:#888;font-size:11px}.dg-form-section textarea{border:2px solid #e8eaf0;border-radius:10px;font-family:inherit;font-size:14px;height:100px;outline:none;padding:10px 12px;resize:none}.dg-form-section textarea:focus{border-color:#1a237e}.dg-stats-auto{background:#f9f9f9;color:#666;display:flex;flex-wrap:wrap;gap:12px}.dg-goi-y,.dg-stats-auto{border-radius:10px;font-size:13px;padding:10px 14px}.dg-goi-y{font-weight:500}.dg-char-count{color:#999;font-size:10px;text-align:right}.dg-error{color:#c62828;font-size:11px}.dg-radio-group{display:flex;flex-wrap:wrap;gap:6px}.dg-radio-btn{background:#fff;border:2px solid #e0e0e0;border-radius:20px;color:#666;cursor:pointer;font-size:12px;font-weight:600;padding:8px 12px}.dg-radio-btn.active{background:#1a237e;border-color:#1a237e;color:#fff}.dg-quick-notes{display:flex;flex-wrap:wrap;gap:4px}.dg-quick-note-btn{background:#fafafa;border:1px solid #e0e0e0;border-radius:14px;color:#666;cursor:pointer;font-size:11px;padding:4px 10px}.dg-quick-note-btn:hover{background:#e8eaf6;border-color:#1a237e}.dg-xeploai-cards{display:flex;flex-direction:column;gap:6px}.dg-xl-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;font-size:14px;font-weight:600;padding:12px;position:relative;text-align:left}.dg-xl-card.active{border-width:2px}.dg-xl-card.suggested{border-style:dashed}.dg-suggested-badge{font-size:10px;position:absolute;right:8px;top:50%;transform:translateY(-50%)}.dg-tt-item{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;font-size:13px;gap:8px;padding:8px 10px}.dg-tt-item button{background:none;border:none;color:#c62828;cursor:pointer}.dg-tt-add{display:flex;gap:6px}.dg-tt-add input{border:1px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:13px;outline:none;padding:8px 10px}.dg-tt-add button{background:#1a237e;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:8px 14px}.dg-dkll{border-radius:10px;font-size:13px;font-weight:500;padding:12px;text-align:center}.dg-dkll.du{background:#e8f5e9;color:#2e7d32}.dg-dkll.chua-du{background:#ffebee;color:#c62828}.dg-form-buttons{display:flex;gap:10px}.dg-btn-draft{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:12px;flex:1 1}.dg-btn-draft,.dg-btn-submit{cursor:pointer;font-size:14px;font-weight:600;padding:12px}.dg-btn-submit{background:linear-gradient(135deg,#1a237e,#283593);border:none;border-radius:12px;color:#fff;flex:2 1}.dg-btn-draft:disabled,.dg-btn-submit:disabled{opacity:.6}@media (max-width:500px){.dg-container{padding:0 8px 30px}.dg-header h2{font-size:17px}}
/*# sourceMappingURL=main.43f2311b.css.map*/