:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:#ffffffde;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#27262b;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;font-weight:400;line-height:1.5}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}a{color:#646cff;-webkit-text-decoration:inherit;text-decoration:inherit;font-weight:500}a:hover{color:#535bf2}body{box-sizing:border-box;width:100%;min-height:100vh;margin:0;padding:0;overflow:auto}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100%;display:flex}h1{font-size:3.2em;line-height:1.1}button{cursor:pointer;background-color:#1a1a1a;border:1px solid #0000;border-radius:8px;padding:.6em 1.2em;font-family:inherit;font-size:1em;font-weight:500;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{width:100%;margin:0;padding:0}:root{--bg-body:#27262b;--bg-container:#27262b;--text-color:#fff;--border-color:#515058;--primary-purple:#711aff;--header-text:#fff;--dropdown-bg:#2b2d31;--dropdown-item-hover:#3f3f46;--input-bg:#3f3f46;--modal-bg:#1e1e1e;--text-muted:#999;--dropdown-border:#454545}.light-mode{--bg-body:#fff;--bg-container:#fff;--text-color:#000;--border-color:#c1c1c1;--primary-purple:#9d00ff;--header-text:#fff;--dropdown-bg:#f5f5f5;--dropdown-item-hover:#e0e0e0;--input-bg:#e0e0e0;--modal-bg:#fff;--text-muted:#555;--dropdown-border:#ccc}body{color:var(--text-color);transition:background-color .3s,color .3s;overflow-x:hidden;background-color:var(--bg-body)!important}.app-container{box-sizing:border-box;background-color:var(--bg-container);flex-direction:column;flex:1;width:100%;max-width:1400px;margin:0 auto;padding:40px 15%;display:flex;position:relative}.table-wrapper{border-radius:6px;width:100%;padding-bottom:10px;overflow-x:visible}.navbar{background:var(--bg-container);color:var(--text-color);border-bottom:1px solid #4f4f4f;padding:15px 15%;font-size:20px;font-weight:700}.light-mode .navbar{background:#f0f0f0;border-bottom:1px solid #ccc}.footer{background:var(--bg-container);border-top:1px solid #4f4f4f;flex-direction:column;justify-content:center;align-items:center;gap:24px;margin-top:auto;padding:40px 20px;display:flex}.footer-links{flex-wrap:wrap;justify-content:center;gap:40px;display:flex}.footer-icons{align-items:center;gap:24px;display:flex}.light-mode .footer{background:#f0f0f0;border-top:1px solid #ccc}.light-mode .footer h2,.light-mode .footer a{color:#333!important}.light-mode .footer a:hover{color:var(--primary-purple)!important}.app-container h1{text-align:center;color:var(--text-color);margin-bottom:30px;font-size:3rem;font-weight:800;line-height:1.2}.grade-table{border-collapse:separate;border-spacing:0;width:100%;color:var(--text-color);border:1px solid var(--border-color);table-layout:fixed;background:0 0;border-radius:6px 6px 0 0;min-width:auto;font-size:14px}.col-stt{width:40px}.col-mahp{width:80px}.col-tenhp{width:25%;min-width:150px}.col-tc{width:50px}.col-score{width:60px}.col-diemhp{width:80px}.col-expected{width:90px}.grade-table th{border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);background:var(--primary-purple);white-space:normal;vertical-align:middle;padding:10px 8px;font-weight:600;color:#fff!important}.grade-table th:first-child{border-top-left-radius:5px}.grade-table th:last-child{border-right:none;border-top-right-radius:5px}.grade-table td{border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);vertical-align:middle;color:var(--text-color);padding:8px 6px}.grade-table td:last-child{border-right:none}.grade-table tr:last-child td{border-bottom:none}.semester-bg{background:var(--primary-purple);color:#fff!important}.semester-title{color:var(--text-color);background:0 0;font-weight:700}.semester-header-td{position:relative;padding-left:12px!important}.btn-header-action{cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:12px}.btn-add{color:#8c8c8c;margin-left:10px}.btn-delete{color:#ff4d4f;margin-left:4px}.summary-label{padding-left:12px!important}.editable-cell{width:100%;color:var(--text-color);white-space:nowrap;text-overflow:ellipsis;cursor:pointer;background:0 0;border:none;outline:none;min-height:20px;line-height:1.4;overflow:hidden}.editable-cell-multiline{white-space:normal;overflow-wrap:break-word}.expected-score-cell{white-space:pre-wrap;text-align:center;box-sizing:border-box;justify-content:center;align-items:center;width:100%;height:100%;padding-right:0;font-size:13px;line-height:1.2;display:flex;overflow:visible}.row-action-dots{cursor:pointer;z-index:5;color:#888;justify-content:center;align-items:center;width:24px;padding:4px;font-size:18px;display:flex;position:absolute;top:50%;right:-26px;transform:translateY(-50%)}.score-cell{text-align:center;vertical-align:middle;padding:4px}.score-content{white-space:normal;overflow-wrap:break-word;cursor:text;background:0 0;border:none;outline:none;justify-content:center;align-items:center;width:100%;display:flex}.theme-toggle-container{cursor:pointer;box-sizing:border-box;background:#4f4f4f;border-radius:30px;justify-content:space-between;align-items:center;width:60px;height:30px;padding:0 5px;transition:background .3s;display:flex;position:relative}.toggle-icon-placeholder{font-size:14px}.theme-toggle-container.dark .toggle-icon-placeholder.left,.theme-toggle-container.light .toggle-icon-placeholder.right{opacity:.5}.theme-toggle-circle{background:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:left .3s ease-in-out;display:flex;position:absolute;top:3px;left:3px;box-shadow:0 2px 4px #0003}.theme-toggle-container.dark .theme-toggle-circle{left:33px}.text-white{color:#fff!important}.text-normal{color:var(--text-color)}.score-over-10{color:red;font-weight:700}.text-yellow{color:#ff0}.light-mode .text-yellow{color:#d32f2f}.text-gray{color:#888}.cursor-not-allowed{cursor:not-allowed}[data-placeholder]:empty:before{content:attr(data-placeholder);color:var(--text-muted);white-space:pre-wrap;font-size:.9em;font-style:italic}.dropdown-menu{background:var(--dropdown-bg);border:1px solid var(--dropdown-border);z-index:20;border-radius:8px;flex-direction:column;max-height:400px;display:flex;position:absolute;top:35px;left:0;overflow-y:hidden;box-shadow:0 10px 20px #00000080}.dropdown-search-container{border-bottom:1px solid var(--dropdown-border);background:var(--dropdown-bg);border-radius:8px 8px 0 0;padding:8px}.search-input-wrapper{background:var(--input-bg);border-radius:6px;align-items:center;padding:0 8px;display:flex;position:relative}.search-icon{color:#a1a1aa;min-width:14px;margin-right:6px}.dropdown-input{width:100%;color:var(--text-color);background:0 0;border:none;outline:none;padding:8px 0;font-size:13px}.dropdown-input::placeholder{color:#a1a1aa}.dropdown-content{max-height:350px;overflow-y:auto}.category-header{color:var(--text-color);cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;font-weight:700;display:flex}.category-header:hover{background:#ffffff0d}.light-mode .category-header:hover{background:#0000000d}.subject-list{background:#0003}.light-mode .subject-list{background:#00000008}.subject-item{cursor:pointer;color:var(--text-color);border-left:2px solid #0000;align-items:center;gap:10px;padding:8px 12px 8px 20px;font-size:13px;display:flex}.subject-item:hover{background:var(--dropdown-item-hover);border-left:2px solid var(--primary-purple)}.subject-code{min-width:45px;color:var(--text-color);font-weight:700}.subject-name{color:var(--text-color);opacity:.9}@media (max-width:1024px){.app-container{padding:30px 40px 0}.navbar{padding:15px 40px}.footer{padding:30px 15px}.table-wrapper{padding-bottom:0}.col-mahp{width:70px}.col-score{width:45px}.col-diemhp{width:65px}.col-expected{width:75px}.col-tenhp{min-width:120px}}@media (max-width:768px){.app-container{padding:20px 10px 50px}.navbar{padding:10px}.footer{padding:30px 10px;text-align:center!important}.app-container h1{margin-bottom:20px;font-size:2rem}.table-wrapper{padding-right:0;overflow-x:visible!important}.grade-table{margin-right:0;width:calc(100% - 10px)!important}.col-stt{width:30px}.col-mahp{width:55px}.col-tenhp{min-width:100px}.col-tc,.col-score{width:35px}.col-diemhp{width:50px}.col-expected{width:60px}.grade-table th,.grade-table td{padding:6px 4px;font-size:11px}.editable-cell,.score-content,.expected-score-cell,input{font-size:11px}}@media (max-width:480px){.app-container{width:100%;overflow-x:hidden;padding:10px 12px!important}.table-wrapper{padding-bottom:0;overflow-x:visible!important}.navbar{min-height:32px;padding:5px 12px!important;font-size:12px!important}.theme-toggle-container{width:42px;height:22px}.theme-toggle-circle{width:16px;height:16px;top:3px;left:3px}.theme-toggle-container.dark .theme-toggle-circle{left:23px}.row-action-dots{right:-26px}.app-container h1{margin-bottom:10px;font-size:1.2rem}.grade-table{min-width:0;font-size:9px;width:calc(100% - 10px)!important;margin-right:0!important}.grade-table th,.grade-table td{padding:2px 1px}.btn-header-action{padding:1px 3px!important;font-size:8px!important}.btn-add{margin-left:5px!important}.btn-delete{margin-left:2px!important}.semester-header-td{padding-left:2px!important}.semester-title span{font-weight:700;font-size:9px!important}.summary-label{white-space:normal;line-height:1.1;padding-left:2px!important;font-size:7px!important}.col-stt{width:20px}.col-mahp{width:40px}.col-tc{width:22px}.col-score{width:25px}.col-diemhp{width:35px}.col-expected{width:45px}.col-tenhp{width:auto;min-width:50px}.editable-cell,.score-content,.expected-score-cell,input{min-height:14px;font-size:8px}[data-placeholder]:empty:before{font-size:8px}.footer{gap:15px!important;padding:10px 5px!important;font-size:10px!important}.footer-links{gap:15px!important}.footer-icons{gap:12px!important}.footer h2{margin:0;font-size:12px!important}.footer a{font-size:10px!important}.dropdown-menu{min-width:140px!important;max-width:240px!important}.dropdown-search-container{padding:5px!important}.dropdown-input{padding:4px 0!important;font-size:11px!important}.search-input-wrapper{padding:0 5px!important}.search-icon{width:10px!important;min-width:10px!important;height:10px!important;margin-right:4px!important}.category-header{padding:5px 8px!important;font-size:10px!important}.subject-item{padding:6px 8px!important;font-size:10px!important}.subject-code{min-width:35px!important;font-size:10px!important}.dropdown-menu>div[role=menuitem]{padding:6px 8px!important;font-size:10px!important}}.footer-icon-fb{width:12px;height:12px}.footer-icon-std{width:14px;height:14px}@media (min-width:768px){.footer-icon-fb{width:17px;height:17px}.footer-icon-std{width:20px;height:20px}}
